In this exercise, you are provided with the same module add16 as the previous exercise, which adds two 16-bit numbers with carry-in and produces a carry-out and 16-bit sum. You must instantiate *three* of these to build the carry-select adder, using your own 16-bit 2-to-1 multiplexer.

Connect the modules together as shown in the diagram below. The provided module add16 has the following declaration:

module add16 ( input[15:0] a, input[15:0] b, input cin, output[15:0]
sum, output cout );



(/wiki/File:Module\_cseladd.png)

## **Module Declaration**

```
module top_module(
    input [31:0] a,
    input [31:0] b,
    output [31:0] sum
);
```

## Write your solution here

```
module top_module(
input [31:0] a,
input [31:0] b,
output [31:0] sum

);
endmodule
```

Submit

Submit (new window)

Upload a source file... ¥

module\_addsub (/wiki/module\_addsub) →

Retrieved from "http://hdlbits.01xz.net/mw/index.php?title=Module\_cseladd&oldid=1443 (http://hdlbits.01xz.net/mw/index.php?title=Module\_cseladd&oldid=1443)"

Category (/wiki/Special:Categories): Modules (/wiki/Category:Modules)

## **Problem Set Contents**

- ▶ Getting Started
- ▼ Verilog Language
  - ▶ Basics
  - ▶ Vectors
  - ▼ Modules: Hierarchy

    - ◆ Connecting ports by position (/wiki/module\_pos)
    - **⊘** Connecting ports by name (/wiki/module\_name)
    - ◆ Three modules (/wiki/module\_shift)
    - Modules and vectors (/wiki/module\_shift8)

- ◆ Adder 1 (/wiki/module\_add)
- Adder 2 (/wiki/module\_fadd)
- Carry-select adder (/wiki/module\_cseladd)
- O Adder-subtractor (/wiki/module\_addsub)
- ▶ Procedures
- ▶ More Verilog Features
- ▶ Circuits
- ▶ Verification: Reading Simulations
- ▶ Verification: Writing Testbenches